import router from '@/router'
import nprogress from 'nprogress'
import 'nprogress/nprogress.css'
import store from '@/store'

/**
 * 前置守卫
 * @param {*} to 到哪里去
 * @param {*} from 从哪里来
 * @param {*} next 允许通过
 */

const whiteList = ['/login', '/404']
router.beforeEach(async(to, from, next) => {
  nprogress.start()
  if (store.getters.token) {
    // 有token
    if (to.path === '/login') {
      next('/') // 跳转到主页
      // next(有地址) 不会执行后置守卫
      nprogress.done() // 手动关闭进度条
    } else {
      // 没有token，判断是否有用户资料
      if (!store.getters.userId) {
        await store.dispatch('user/getUserInfo')
      }
      next() // 直接放行
    }
  } else {
    // 没有token
    if (whiteList.includes(to.path)) {
      // 白名单放行
      next()
    } else {
      // 其他页面跳转到登录页
      next('/login')
      nprogress.done()
    }
  }
})

/**
 * 后置守卫
 */

router.afterEach(() => {
  nprogress.done()
})
